CLAIMS 


What is claimed is: 


1 LA method for reorganizing a database table online, the method steps comprising: 

2 a) moving a subset of records within the database table; 

3 b) flagging each moved record as a reorganization record; 

4 c) creating a reorganization pointer record for each moved record at the 

5 initial location of the moved record, the reorganization pointer record pointing to the new 

6 location of the moved record; and 

CI 7 d) establishing scanner process constraints based on whether a scanner 

!?; 8 process is commenced prior to or after the moving. 

S J* 1 2. The method of claim 1 wherein the establishing further comprises: 

2 dl) identifying table and index scanner processes commencing prior to the 

lO 3 completion of the moving as old table scanners wherein old table scanners are 

^ 4 constrained to access records in the database table by following reorganization pointers to 

5 access reorganization records and wherein old table scanners are constrained to ignore 

6 reorganization records when accessing records sequentially in a scan of the database 

7 table; and 

8 d2) identifying table and index scanner processes commencing after the 

9 completion of the moving as new table scanners, wherein new table scanners are 

10 constrained to ignore reorganization pointers in accessing records in the database table. 
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1 3 . The method of claim 2 further comprising the steps of: 

2 e) deleting the reorganization pointer records and removing the 

3 reorganization record flag from the records flagged after each query associated with an 

4 old table scanner is complete; and 

5 f) repeating steps a-d after the completion of each query associated with a 

6 new scanner until the records in the database table meet a reorganization criteria, 

1 4. The method of claim 3 in which step f) alternates between moving records from a 

2 one of successively defined portions of the table and moving records in a predefined 
; €h order into a one of the successively defined vacated portions of the table. 

*M 1 5, The method of claim 4 in which the predefined order for moving records is 

3 2 defined by a clustering index associated with the table. 

FU 

yQ i ■ 6. The method of claim 4 in which the table further comprises overflow pointer 

O 

¥ "2 records pointing to overflow records and in which the method steps further comprise 

3 steps defining each overflow pointer record in a one of the successively defined portions 

4 of the table to be a reorganization overflow pointer record, and flagging the associated 

5 overflow record to be a reorganization record. 

1 7. The method of claim 4 in which the method steps further comprise the step of 

2 preventing the allocation of space for new or updated records in each respective one of 

3 the successively defined portions of the table when moving records from the one of 
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4 successively defined portions of the table. 

1 8. The method of claim 3 wherein the deleting further comprises requesting and 

2 waiting for the exclusive availability of a latch which is shareable by each old table 

3 scanner process and which each old table scanner process obtains before commencing 

4 scanning and releases after the query associated with the old table scanner process has 

5 completed processing . 

1 9. The method of claim 8 in which the latch is shareable by each index scanner 

kQ2 process and each index scanner process obtains the latch before commencing scanning 

H3 and releases the latch after the query associated with the index scanner process has 

IJf 4 completed processing. 

P 

y 3 1 1 0. The method of claim 3 in which the method steps further comprise steps to 

i y 

yi2 maintain the identity and status of moved records in a record identifier mapping table. 

1 11. The method of claim 1 0 in which the record identifier mapping table comprises a 

2 mapping record corresponding to each of the moved records, each mapping record 

3 comprising an old record identifier for the initial position of the moved record, a new 

4 record identifier for the moved position of the moved record, and a status flag for the 

5 moved record. 

1 12. The method of claim 1 1 in which the status flag for the moved record comprises 
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flags to indicate the completion of the move of the record, the completion of the clean up 
for the record, and whether the record has been deleted. 

1 3 . The method of claim 1 0 in which the record identifier mapping table comprises a 
hash table implemented having a hash on the new record identifier, and a hash table 
containing a reverse record identifier mapping. 

14. The method of claim 3 in which the method steps further comprise logging steps 
for retaining data values relating to: 

1) the start of step a), 

2) the move of a normal record, 

3) the move of a pointer record where, when moving records from a one of 
successively defined portions of the table, the associated overflow record is not in the 
vacate range, 

4) the move of a pointer record where, when moving records from a one of 
successively defined portions of the table, the associated overflow record is in the vacate 
range, 

5) the move of an overflow record during a vacate phase, 

6) the successful move of a record, 

7) the successful clean up of a row that has been moved, and 

8) the completion of the online reorganization, " 

wherein the table may be rolled back without the loss of data due to the 
reorganization of the table. 
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15. The method of claim 3 in which the method steps further comprise the step of 
imposing a key value lock where an index scanner is accessing an ordered list of key 
values in an index associated with the table, the key value lock preventing index values 
from being updated while the index scanner accesses the ordered list of key values. 

16. The method of claim 3 in which the method steps further comprise the step of 
synchronising between scanners by imposing a share lock on records subject to the 
moving and records subject to the deleting. 

1 7. The method of claim 3 in which the method steps further comprise an idle step in 
which neither the moving nor the deleting is performed. 

18. A method for reorganizing a database table the method comprising the steps of: 

a) a vacate move step; 

b) a vacate clean up step; 

c) a fill move step; and 

d) a fill clean up step wherein each clean up step is synchronised to 
commence at the completion of a move step and to commence only when all queries 
launching scanner processes commenced before the completion of a move step have 
completed and each move step is synchronised to commence at the completion of a clean 
up step and to commence only when all queries launching scanner processes after the 
completion of a previous move step have completed. 
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19. The method of claim 18 wherein step a) comprises: 

i) moving each data record in a defined set of pages to a new location in a 
page in the database table outside the defined set of pages; 

ii) flagging each moved non-overflow data record as a reorganization record; 

iii) creating a reorganization pointer record for each moved non-overflow data 
record at the initial location of the moved record, the reorganization pointer record 
pointing to the new location of the moved record; 

iv) for each overflow pointer record located in the defined set of pages and 
associated with a moved overflow data record, creating a reorganization pointer record 
for the moved overflow data record at the location of the said reorganization pointer 
record and flagging the moved overflow record as a reorganization record; and 

v) flagging each overflow pointer record pointing to an overflow record 
outside the defined set of pages to be a reorganization pointer record, and flagging each 
of said overflow records as a reorganization record. 

20. The method of claim 1 9 wherein step b) comprises: 

i) deleting reorganization pointers in the defined set of pages; and 

ii) removing the reorganization record flag from each reorganization record 
in the database table. 

21 . The method of claim 20 wherein step c) comprises: 

i) moving selected records to the defined set of pages such that the relative 
ordering of the selected records matches the predefined ordering constraint; 
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ii) flagging each moved record as a reorganization record; 

iii) creating a reorganization pointer record for each moved non-overflow 
record at the initial location of the moved record, the reorganization pointer record 
pointing to the new location of the moved record; 

iv) creating a reorganization pointer record for each moved overflow record at 
the location of the overflow pointer record for the moved record, the reorganization 
pointer record pointing to the new location of the moved record. 

22. The method of claim 21 wherein step d) comprises: 

i) deleting reorganization pointers in the defined set of pages; and 

ii) removing the reorganization record flag from each reorganization record 
in the database table. 

23 . The method of claim 22, wherein table scanner processes commencing during 
each move step are identified as old table scanners, wherein old table scanners are 
constrained to access records in the database table by following reorganization pointers to 
access reorganization records and are further constrained to access reorganization records 
sequentially by ignoring reorganization records and table scanner processes commencing 
after the completion of a move step are identified as new table scanners, wherein new 
table scanners ignore reorganization pointers in accessing records in the database table. 

24. * The method of claim 22 in which each clean up synchronisation step comprises 
requesting and waiting for the exclusive availability of a latch which is shareable by each 
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old table scanner process and which each old table scanner process obtains before 
commencing scanning. 

25. The method of claim 22 in which the method further comprises the step of 
preventing the allocation of space for new or updated records in each respective one of a 
sequentially advancing defined set of pages during the vacate move step for the said one 
of the sequentially advancing defined set of pages. 

26. The method of claim 22 in which an identity and status of moved records is 
maintained in a record identifier mapping table. 

27. The method of claim 26 in which the record identifier mapping table comprises a 
mapping record corresponding to each of the moved records, each mapping record 
comprising an old record identifier for the initial position of the moved record, a new 
record identifier for the moved position of the moved record, and a status flag for the 
moved record, 

28. The method of claim 27 in which the record identifier mapping table comprises a 
hash bucket comprising a hash on the new record identifier, and a hash table containing a 
reverse record identifier mapping. 

29. The method of claim 22 in which the database table has an associated index and 
in which each fill step selects records by scanning the associated index of the database 
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table. 


30. A method for reorganizing a database table online, the method comprising the 
following steps: 

a) a vacate move step to move data records from move pages in the table; 

and 

b) a fill move step to move data records into move pages in the table. 

31. The method of claim 30 wherein each move step comprises the step of defining 
temporary pointers from the original position of each moved record to the moved position 
of the moved record. 

32. The method of claim 3 1 further comprising the step of 

c) defining selected scanners to be constrained to follow the temporary 
pointers while accessing records so as to maintain data ordering for the selected scanners 
wherein the move steps are synchronised with query processes launching scanners so as ' 
to maintain the temporary pointers for use by said scanners launched by query processes. 

33. The method of claim 32 in which the database table comprises overflow pointer 
records and the original position of a moved record from which a temporary pointer 
points. 


34. A computer readable medium containing program instructions for reorganizing a 
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database table online, the program instructions comprising the steps of: 

a) moving a subset of records within the database table; 

b) flagging each moved record in as a reorganization record; 

c) creating a reorganization pointer record for each moved record in at the 
initial location of the moved record, the reorganization pointer record pointing to the new 
location of the moved record; and 

d) establishing scanner process constraints based on whether a scanner 
process is commenced prior to or after the moving. 

35. The computer readable medium of claim 34 wherein step d) further comprises: 
dl) identifying table and index scanner processes commencing prior to the 
completion of the moving as old table scanners wherein old table scanners are 
constrained to access records in the database table by following reorganization pointers to 
access reorganization records and wherein old table scanners are constrained to ignore 
reorganization records when accessing records sequentially in a scan of the database 
table; and 

d2) identifying table and index scanner processes commencing after the 
completion of the moving as new table scanners, wherein new table scanners are 
constrained to ignore reorganization pointers in accessing records in the database table. 

36. The computer readable medium of claim 35 further comprising the steps of: 

e) deleting the reorganization pointer records and removing the 
reorganization record flag from the records flagged after each query associated with an 
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old table scanner is complete; and 

f) repeating steps a-d after the completion of each query associated with a 
new scanner until the records in the database table meet a reorganization criteria. 

37. The computer readable medium of claim 36 in which step f) alternates between 
moving records from a one of successively defined portions of the table and moving 
records in a predefined order into a one of the successively defined vacated portions of 
the table. 


38, A computer readable medium containing program instructions for reorganizing a 
database table online, the program instructions comprising the steps of: 

a) a vacate move step; 

b) a vacate clean up step; 

c) a fill move step; and 

d) a fill clean up step wherein each clean up step is synchronised to 
commence at the completion of a move step and to commence only when all queries 
launching scanner processes commenced before the completion of a move step have 
completed and each move step is synchronised to commence at the completion of a clean 
up step and to commence only when all queries launching scanner processes after the 
completion of a previous move step have completed. 

39. The computer readable medium of claim 38 wherein step a) comprises: 

i) moving each data record in a defined set of pages to a new location in a 
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page in the database table outside the defined set of pages; 

ii) flagging each moved non-overflow data record as a reorganization record; 

iii) creating a reorganization pointer record for each moved non-overflow data 
record at the initial location of the moved record, the reorganization pointer record 
pointing to the new location of the moved record; 

iv) for each overflow pointer record located in the defined set of pages and 
associated with a moved overflow data record, creating a reorganization pointer record 
for the moved overflow data record at the location of the said reorganization pointer 
record and flagging the moved overflow record as a reorganization record; and 

v) flagging each overflow pointer record pointing to an overflow record 
outside the defined set of pages to be a reorganization pointer record, and flagging each 
of said overflow records as a reorganization record. 

40. The computer readable medium of claim 39 wherein step b) comprises: 

i) deleting reorganization pointers in the defined set of pages; and 

ii) removing the reorganization record flag from each reorganization record 
in the database table. 

4 1 . The computer readable medium of claim 40 wherein step c) comprises: 

i) moving selected records to the defined set of pages such that the relative 
ordering of the selected records matches the predefined ordering constraint; 

ii) flagging each moved record as a reorganization record; 

iii) creating a reorganization pointer record for each moved non-overflow 
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record at the initial location of the moved record, the reorganization pointer record 
pointing to the new location of the moved record; and 

iv) creating a reorganization pointer record for each moved overflow record at 
the location of the overflow pointer record for the moved record, the reorganization 
pointer record pointing to the new location of the moved record. 

42. The computer readable medium of claim 41 wherein step d) comprises: 

i) deleting reorganization pointers in the defined set of pages; and 

ii) removing the reorganization record flag from each reorganization record 
in the database table. 

43. The computer readable medium of claim 42, wherein table scanner processes 
commencing during each move step are identified as old table scanners, wherein old table 
scanners are constrained to access records in the database table by following 
reorganization pointers to access reorganization records and are further constrained to 
access reorganization records sequentially by ignoring reorganization records and table 
scanner processes commencing after the completion of a move step are identified as new 
table scanners, wherein new table scanners ignore reorganization pointers in accessing 
records in the database table. 
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44. A computer readable medium for reorganizing a database table online, the method 
comprising the following steps: 

a) a vacate move step to move data records from move pages in the table; 

and 

b) a fill move step to move data records into move pages in the table. 

45. The computer readable medium of claim 44 wherein each move step comprises 
the step of defining temporary pointers from the original position of each moved record 
to the moved position of the moved record. 

46. The computer readable medium of claim 45 further comprising the step of 

c) defining selected scanners to be constrained to follow the temporary 
pointers while accessing records so as to maintain data ordering for the selected scanners 
wherein the move steps are synchronised with query processes launching scanners so as 
to maintain the temporary pointers for use by said scanners launched by query processes. 

47. A computer system for reorganizing a database table online, the computer system 
comprising 

means for moving a subset of records within the database table; 

means for flagging each record moved by the means for moving a subset of 
records as a reorganization record; 

means for creating a reorganization pointer record for each record moved by the 
means for moving a subset of records at the initial location of the moved record, the 


CA9-1999-0047US1/1796P 


47 


reorganization pointer record pointing to the new location of the moved record; and 

means for establishing scanner process constraints based on whether a scanner 
process is commenced prior to or after moving the subset of records. 

48. The computer system of claim 47 wherein the means for establishing scanner 
process constraints further comprises: 

means for identifying table and index scanner processes commencing prior to 
moving the subset of records as old table scanners wherein old table scanners are 
constrained to access records in the database table by following reorganization pointers to 
access reorganization records and wherein old table scanners are constrained to ignore 
reorganization records when accessing records sequentially in a scan of the database 
table; and 

means for identifying table and index scanner processes commencing after the 
completion of moving the subset of records as new table scanners, wherein new table 
scanners are constrained to ignore reorganization pointers in accessing records in the 
database table. 

49. The computer system of claim 48 further comprising: 

means for deleting the reorganization pointer records and removing the 

reorganization record flag from the records by the means for flagging after each query 

associated with an old table scanner is complete; and 

means for moving another subset of records after the completion of each query 

associated with a new scanner until the records in the database table meet a 
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reorganization criteria. 

50. The computer system of claim 49 in which the means for moving another subset 
of records alternates between moving records from a one of successively defined portions 
of the table and moving records in a predefined order into a one of the successively 
defined vacated portions of the table. 

51. A computer system for reorganizing a database table comprising: 
means for performing a vacate move step; 

means for performing a vacate clean up step; 
means for performing a fill move step; and 

means for performing a fill clean up step wherein each clean up step is 
synchronised to commence at the completion of a move step and to commence only when 
all queries launching scanner processes commenced before the completion of a move step 
have completed and each move step is synchronised to commence at the completion of a 
clean up step and to commence only when all queries launching scanner processes after 
the completion of a previous move step have completed. 

52. The computer system of claim 5 1 wherein the means for performing the vacate 
move step comprises: 

means for moving each data record in a defined set of pages to a new 
location in a page in the database table outside the defined set of pages; 

means for flagging each moved non-overflow data record as a reorganization 
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6 record; 

7 means for creating a reorganization pointer record for each moved non-overflow 

8 data record at the initial location of the moved record, the reorganization pointer record 

9 pointing to the new location of the moved record; 

10 means for each overflow pointer record located in the defined set of pages and 

1 1 associated with a moved overflow data record, creating a reorganization pointer record 

12 for the moved overflow data record at the location of the said reorganization pointer 

13 record and flagging the moved overflow record as a reorganization record; and 

14 means for flagging each overflow pointer record pointing to an overflow record 
.J 5 outside the defined set of pages to be a reorganization pointer record, and flagging each 
%16 of said overflow records as a reorganization record. 

■ill 

2"*""b 

J yi 53. The computer system of claim 52 wherein the means for performing the vacate 

"^2 clean up step comprises: 

means for deleting reorganization pointers in the defined set of pages; and 

bd means for removing the reorganization record flag from each reorganization 

5 record in the database table. 

1 54. The computer system of claim 53 wherein the means for performing the fill move 

2 step comprises: 

3 means for moving selected records to the defined set of pages such that the 

4 relative ordering of the selected records matches the predefined ordering constraint; 

5 means for flagging each moved record as a reorganization record; 
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6 means for creating a reorganization pointer record for each moved non-overflow 

7 record at the initial location of the moved record, the reorganization pointer record 

8 pointing to the new location of the moved record; and 

9 means creating a reorganization pointer record for each moved overflow record at 

10 the location of the overflow pointer record for the moved record, the reorganization 

1 1 pointer record pointing to the new location of the moved record. 

1 55. The computer system of claim 54 wherein the means for performing the fill clean 

2 up step comprises: 

^ 3 means for deleting reorganization pointers in the defined set of pages; and 

-Jl4 means for removing the reorganization record flag from each reorganization 

4|5 record in the database table. 

pi 56. The computer system of claim 55 further comprising: 

v *jL means for identifying table scanner processes commencing during the 

r 3 performance of each move step as old table scanners, wherein old table scanners are 

4 constrained to access records in the database table by following reorganization pointers to 

5 access reorganization records and are further constrained to access reorganization records 

6 sequentially by ignoring reorganization records; and 

7 means for identifying table scanner processes commencing after the completion of 

8 the performance of a move step as new table scanners, wherein new table scanners ignore 

9 reorganization pointers in accessing records in the database table. 
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57. A computer system for reorganizing a database table online, the computer system 
comprising: 

a) means for carrying out a vacate move step to move data records from 
move pages in the table; and 

b) means for carrying out a fill move step to move data records into the move 
pages in the table. 

58. The computer system of claim 57 further comprising: 

means for defining temporary pointers from an original position of each moved 
record to the moved position of the moved record; 

means for defining selected scanners to be constrained to follow the temporary 
pointers while accessing records so as to maintain data ordering for the selected scanners; 
and 

means for synchronising the move steps with query processes launching scanners 
so as to maintain the temporary pointers for use by said scanners launched by query 
processes, 

59. The computer system of claim 58 in which the database table comprises overflow 
pointer records and the computer system further comprises means for setting the original 
position of a moved record to be the position of an overflow pointer record, from which a 
temporary pointer points, where the moved data record is originally pointed to by said 
overflow pointer record. 
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